### DCS Lab02

隋建德 郭書宏 許仲緯

# Sorting

- 輸入四個數字{in\_num0, in\_num1, in\_num2, in\_num3}
- 將四個數字以小至大進行排序之後
- 以{out\_num0, out\_num1, out\_num2, out\_num3}輸出
- Ex: 輸入數字: 4, 3, 1, 2 → 輸出: 1, 2, 3, 4
  - Bubble sort, Merge sort

# Sorting

- 氣泡排序法 (Bubble sort)
  - Easy for software
  - Use recursive function, for loop
- 合併排序法 (Merge sort)
  - Easy for hardware
  - Use comparator

# 參考架構 (Merge Sort)





# 參考架構 (Merge Sort)



### Sort.sv

| Input Signal | Bit width | Definition            |  |
|--------------|-----------|-----------------------|--|
| in_num0      | 6         | Dandana Chitananahana |  |
| in_num1      | 6         |                       |  |
| in_num2      | 6         | Random 6-bit numbers  |  |
| in_num3      | 6         |                       |  |

| Output Signal | Bit width | Definition                                            |  |
|---------------|-----------|-------------------------------------------------------|--|
| out_num0      | 6         |                                                       |  |
| out_num1      | 6         |                                                       |  |
| out_num2      | 6         | $out\_num0 \le out\_num1 \le out\_num2 \le out\_num3$ |  |
| out_num3      | 6         |                                                       |  |

#### Command

- tar -xvf ~dcsta01/Lab02.tar
- cd Lab02/01\_RTL/

- gedit (text editor)
  - view → Highlight Mode → Sources → Verilog
  - If you use Windows/MacOS, you can use Notepad++,
     or any editors you are used to using.

# gedit



#### Directory



#### RTL simulation

- cd Lab02/01\_RTL/
- ./01\_run (電路模擬)
- ./09\_clean\_up (清除波型檔)
- nWave & (看波型)
  - 範例波型:



#### Synthesis

- cd ../02\_SYN/
- ./01\_run\_dc (合成電路)
- ./09\_clean\_up (清除合成結果)
  - 合成結果: (不能有Error、要有Area report、
     Timing report slack met、不能有Latch)

```
Number of ports:
                                            48
Number of nets:
                                           185
Number of cells:
                                           161
Number of combinational cells:
                                           161
Number of sequential cells:
Number of macros/black boxes:
                                             Θ
Number of buf/inv:
                                            38
Number of references:
                                            18
Combinational area:
                                   2864.030431
Buf/Inv area:
                                    379.209614
Noncombinational area:
                                      0.000000
Macro/Black Box area:
                                      0.000000
                             undefined (No wire load specified)
Net Interconnect area:
                                   2864.030431
Total cell area:
```

# Synthesis

- 合成的timing report中的 slack必須≥0 (MET)
- 如果出現timing violation
   → Demo Fail

| U875/Y (NAND2X4)<br>U974/Y (NAND3X4)<br>out_n[7] (out)<br>data arrival time | 0.08<br>0.16<br>0.00 | 5.05 r<br>5.21 f<br>5.21 f<br>5.21 |
|-----------------------------------------------------------------------------|----------------------|------------------------------------|
| max_delay<br>output external delay<br>data required time                    | 5.00<br>0.00         | 5.00<br>5.00<br>5.00               |
| data required time Fail!<br>data arrival time                               |                      | 5.00<br>-5.21                      |
| slack (VIOLATED)                                                            |                      | -0.21                              |

| (output port)<br>Path Group: default |              |                  |
|--------------------------------------|--------------|------------------|
| Path Type: max                       |              |                  |
| Point                                | Incr         | Path             |
|                                      | 0.00         | 0.00             |
| input external delay                 | 0.00         | 0.00 r           |
| in_num0[1] (in)                      | 0.00         | 0.00 r<br>0.06 f |
| U250/Y (INVXL)<br>U166/Y (A0I222XL)  | 0.06<br>0.58 |                  |
|                                      | 0.34         | 0.64 r<br>0.98 f |
| U218/Y (A0I222XL)                    |              |                  |
| U307/Y (A0I222XL)                    | 0.58<br>0.20 | 1.56 r<br>1.76 f |
| U308/Y (0AI22X1)                     | 0.20         | 1.76 f<br>2.27 r |
| U309/Y (A0I31X4)<br>U211/Y (MXI2X1)  | 0.25         | 2.27 I<br>2.53 f |
| U205/Y (A0I222X1)                    | 0.45         | 2.33 T           |
| U245/Y (A0I222XI)                    | 0.45         | 3.22 f           |
| U203/Y (A01222XL)                    | 0.34         | 3.56 f           |
| U253/Y (A012BB1XL)                   | 0.23         | 3.79 r           |
| U202/Y (OAI2BB1X1)                   | 0.13         | 3.92 f           |
| U248/Y (A0I21X1)                     | 0.24         | 4.16 r           |
| U201/Y (INVX3)                       | 0.16         | 4.32 f           |
| U313/Y (MXI2X1)                      | 0.24         | 4.56 f           |
| U197/Y (A0I222X1)                    | 0.48         | 5.04 r           |
| U196/Y (A0I222XL)                    | 0.31         | 5.35 f           |
| U314/Y (A0I222XL)                    | 0.45         | 5.81 r           |
| U195/Y (OAI21XL)                     | 0.19         | 5.99 f           |
| U239/Y (A0I2BB1XL)                   | 0.29         | 6.29 f           |
| U315/Y (A0I31X1)                     | 0.28         | 6.57 r           |
| U316/Y (A0I2BB1X2)                   | 0.18         | 6.75 f           |
| U175/Y (INVX2)                       | 0.19         | 6.94 r           |
| U275/Y (MXI2XL)                      | 0.30         | 7.24 r           |
| U172/Y (INVX1)                       | 0.13         | 7.37 f           |
| U185/Y (A0I222X1)                    | 0.40         | 7.77 r           |
| U321/Y (A0I222XL)                    | 0.25         | 8.01 f           |
| U171/Y (A0I2BB1XL)                   | 0.33         | 8.34 f           |
| U183/Y (OAI31XL)                     | 0.23         | 8.57 r           |
| U323/Y (OAI2BB1X1)                   | 0.16         | 8.73 f           |
| U182/Y (A0I21X2)                     | 0.35         | 9.08 r           |
| U170/Y (INVX2)                       | 0.20         | 9.28 f           |
| U332/Y (A0I22X1)                     | 0.72         | 10.00 r          |
| out_numl[0] (out)                    | 0.00         | 10.00 r          |
| data arrival time                    |              | 10.00            |
| max_delay                            | 10.00        | 10.00            |
| output external delay                | 0.00         | 10.00            |
| data required time ´                 |              | 10.00            |
| data required time Dace              |              | 10.00            |
| data arrival time                    |              | -10.00           |

## Synthesis

- 記得檢查是否合成出Latch
  - 可以在syn.log用ctrl+F尋找關鍵字Latch
- 如果出現Latch → Demo Fail

```
Read RTL Code
read sverilog {$DESIGN\.sv}
Loading db file '/usr/synthesis/libraries/syn/dw_foundation.sldb'
Loading db file '/usr/synthesis/libraries/syn/standard.sldb'
Loading db file '/RAID2/COURSE/iclab/iclabta01/umc018/Synthesis/slow.db'
Loading db file '/usr/synthesis/libraries/syn/gtech.db'
Loading link library 'slow'
 Loading link library 'gtech'
Loading sverilog file '/home/RAID2/COURSE/dcs/dcsta02/TA/Lab02/01 RTL/Sort.sv'
Detecting input file type automatically (-rtl or -netlist).
Reading with Presto HDL Compiler (equivalent to -rtl option).
Running PRESTO HDLC
Compiling source file /home/RAID2/COURSE/dcs/dcsta02/TA/Lab02/01 RTL/Sort.sv
Inferred memory devices in process
        in routine Sort line 52 in file
                 '/home/RAID2/COURSE/dcs/dcsta02/TA/Lab02/01_RTL/Sort.sv'.
                         Type
     out num2 req
                        Latch
```

#### Upload

- cd ../09\_UPLOAD/
- ./01\_upload (上傳code)
- ./02\_download [argument] (下載上傳結果)
  - [argument] = demo1 or demo2
  - 檢查是否上傳成功&正確
- Demo1: 3/18, 16:25:00 · Demo2: 3/19, 23:59:59

```
linux01 [Lab02/09_UPLOAD]% ./01_upload

module Sort(
    // Input signals
:
endmodule

The 1st demo deadline is Thu Mar 18 16:25:00 CST 2021 , and the second state of the second state o
```

linux01 [Lab02/09\_UPLOAD]% ./02\_download demo1
Download done!